Reed solomon decoder and ibma method and parallel-to-serial conversion method thereof

ABSTRACT

A parallel-to-serial conversion method for IBMA in a Reed Solomon decoder is used for obtaining discrepancies in IBMA iterations, thereby acquiring an error location polynomial and an error value polynomial. Syndrome sequences for the calculation of discrepancies in IBMA iterations have a fixed length. The number of syndromes is t+1, where t is the largest number of symbols that can be corrected of the error location polynomial. The feature that syndrome sequences have the same length is based on the fact that the discrepancies are not affected if the coefficients of polynomial orders of the error location polynomial are zero.

BACKGROUND OF THE INVENTION

(A) Field of the Invention

The present invention is related to a Reed Solomon decoder and Inversionless Berlekamp-Massey Algorithm (IBMA) and parallel-to-serial conversion method thereof.

(B) Description of the Related Art

Error correction codes (ECC) are in wide use, with respect to current general applications. For example, consumer electronics using high speed digital communications, optic disc storage and high resolution television all use Reed Solomon decoders.

Nowadays, there are many transmission technologies and equipment that are widely used, and transmission rates have increased from 56 Kbps to several gigabytes per second. However, noise interference may occur during signal transmission, resulting in data receiving errors. Therefore, receiving equipment should be simple, popular and have high efficiency error correction capability to correct transmission errors due to channel noises.

U.S. Pat. No. 6,286,123 B1 disclosed a Berlekamp-Massey Algorithm (BMA) in which a parallel-to-serial interface directly uses multiplexers as interfaces. However, control signals are more complicated and divisional operation devices are needed in BMA architecture.

In U.S. Pat. Nos. 6,317,858 B1 and 6,539,516 B2, although the parallel-to-serial interface of IBMA architecture is changed to be of serial entering, it has less regularity and the error value polynomial is calculated after the error location polynomial is obtained.

A parallel-to-serial interface and an IBMA architecture are compared as follows. FIG. 1 illustrates a traditional Reed Solomon decoder 10 including a syndrome calculator 11, a parallel-to-serial (PS) interface 12, an IBMA apparatus 13, a key equation solver 14, a serial-to-parallel (SP) interface 15, a Chien search device 16 (error location) and a Chien search device 17 (error value), a first-in-first-out (FIFO) circuit 18 and a Forney algorithm device 19. The syndrome calculator 11 receives messages r(x) from a receiving end and calculates syndromes. The syndromes are transmitted to the IBMA apparatus 13 through the parallel-to-serial interface 12. The IBMA apparatus 13 generates an error location polynomial Λ(x) based on the syndromes. The key equation solver 14 generates an error value polynomial Ω(x) based on the syndromes and Λ(x). Λ(x) and Ω(x) are transmitted to the Chien search devices 16 and 17 through the serial-to-parallel interface 15 to solve error locations and the Forney algorithm device 19 calculates error values. r(x) is registered in the FIFO circuit 18 and corrected by the error values obtained by the Forney algorithm device 19, so as to obtain messages c(x) at the end of the transmission.

Accordingly, there are problems with the error value polynomial Ω(x) being obtained after the error location polynomial Λ(x) is obtained, and the parallel-to-serial interface has less regularity.

FIG. 2 illustrates a traditional parallel-to-serial interface using multiplexers. The parallel-to-serial interface includes 16 syndrome cells 22 and a multiplexer 21. The corresponding syndrome sequences are shown in Table 1.

TABLE 1 Δ^((i)) Syndrome sequences i = 0 S₁ i = 1 S₂, S₁ i = 2 S₃, S₂, S₁ i = 3 S₄, S₃, S₂, S₁ i = 4 S₅, S₄, S₃, S₂, S₁ i = 5 S₆, S₅, S₄, S₃, S₂, S₁ i = 6 S₇, S₆, S₅, S₄, S₃, S₂, S₁ i = 7 S₈, S₇, S₆, S₅, S₄, S₃, S₂, S₁ i = 8 S₉, S₈, S₇, S₆, S₅, S₄, S₃, S₂, S₁ i = 9 S₁₀, S₉, S₈, S₇, S₆, S₅, S₄, S₃, S₂ i = 10 S₁₁, S₁₀, S₉, S₈, S₇, S₆, S₅, S₄, S₃ i = 11 S₁₂, S₁₁, S₁₀, S₉, S₈, S₇, S₆, S₅, S₄ i = 12 S₁₃, S₁₂, S₁₁, S₁₀, S₉, S₈, S₇, S₆, S₅ i = 13 S₁₄, S₁₃, S₁₂, S₁₁, S₁₀, S₉, S₈, S₇, S₆ i = 14 S₁₅, S₁₄, S₁₃, S₁₂, S₁₁, S₁₀, S₉, S₈, S₇ i = 15 S₁₆, S₁₅, S₁₄, S₁₃, S₁₂, S₁₁, S₁₀, S₉, S₈

The IBMA algorithm is a modification from BMA algorithm, with a view to decreasing hardware complexity, in which divisional operation in BMA is replaced with a non-divisional operation and a multiple of the original polynomial is obtained. According to features of Galois Field, the same root can be solved. This algorithm is used for obtaining the error location polynomial Λ(x). The IBMA architecture and calculation are exemplified as follows.

Initial conditions:

D⁽⁻¹⁾ 32 0 δ= 1 Λ⁽⁻¹⁾(x) = 1 T⁽⁻¹⁾(x) = 1 Δ⁽⁰⁾ = S₁ For i=0 to 2t−1 { Δ^((i+1)) = S_(i+2) * Λ₀ ^((i)) + S_(i+1) *Λ₁ ^((i)) +...+S_(i−vi+2) *Λ_(vi) ^((i)) If Δ^((i)) =0 or 2D^((i−1)) ≧ i+1   D^((i)) = D^((i+1))   T^((i))(x) = x * T^((i−1))(x)   δ = δ   Λ^((i))(x) = Λ^((i−1))(x) Else   D^((i)) = i+1−D^((i−1))   T^((i))(x) = Λ^((i−1))(x)   δ = Δ^((i))   Λ^((i))(x) =δ * Λ^((i−1))(x) +δ^((i)) * x * T^((i−1))(x) }

Ω(x)mod x ^(2t) =S(x)*Λ^((2t))(x)

where

-   -   Λ^((i))(x) is the error location polynomial at ith iteration     -   Λ_(j) ^((i))(x) is coefficients of orders of Λ^((i))(x)         -   j is x order         -   Δ^((i)) is discrepancy of ith iteration         -   δ is discrepancy of T^((i))(x) with corrected iteration         -   T^((i))(x) is an auxiliary polynomial         -   D^((i)) is the highest order of the auxiliary polynomial         -   S(x) is syndrome array S₁˜S_(2t)         -   Ω(x) is a key equation

FIG. 3 illustrates a traditional IBMA apparatus 30, and FIG. 4 illustrates the architecture for calculation of a key equation based on the architecture shown in FIG. 3. The IBMA apparatus 30 comprises multipliers 31, 40 and 41, buffers 32 and 37, adders 33 and 39, multiplexers 35 and 43 and registers 34, 36, 38, 42 and 44.

In order to obtain higher regularity and lower hardware complexity, the separated IBMA algorithm can implement serial input data sequences as shown in Table 1. The error location polynomial and the key equation (error value polynomial) after separation are listed in Table 2.

TABLE 2 Error location polynomial Key equation Λ^((i))(x) = Λ₀ ^((i)) + Λ₁ ^((i))x + . . . + Λ_(vi) ^((i))x^(vi) $\begin{matrix} {{\Omega (x)} = {{S(x)}{\Lambda (x)}\mspace{11mu} {mod}\mspace{11mu} x^{2t}}} \\ {\cong {\Omega^{(0)} + {\Omega^{(1)}x} + {\ldots \mspace{11mu} \Omega^{({v - 1})}x^{v - 1}}}} \end{matrix}$ $\Lambda_{j}^{(i)} = \left\{ \begin{matrix} {{\delta*\Lambda_{0}^{({i - 1})}},} & {j = 0} \\ {{{\delta*\Lambda_{j}^{({i - 1})}} + {\Delta^{(i)}T_{j - 1}^{({i - 1})}}},} & {1 \leq j \leq {vi}} \end{matrix} \right.$ Ω^((i)) = S_(i+1)Λ₀ + S_(i)Λ₁ + . . . + S₁Λ_(i) $\Delta^{({i + 1})} = {\sum\limits_{j = 0}^{vi}\; \Delta_{j}^{({i + 1})}}$ $\Omega_{j}^{(i)} = \left\{ \begin{matrix} {S_{i + 1}\Lambda_{0}} & {{{for}\mspace{14mu} i} = 0} \\ {\Omega_{j - 1}^{(i)} + {S_{i - j + 1}\Lambda_{j}}} & {{{for}\mspace{14mu} 1} \leq j \leq i} \end{matrix} \right.$ $\Delta_{j}^{({i + 1})} = \left\{ \begin{matrix} {0,} & {j = 0} \\ {{\Delta_{j - 1}^{({i + 1})} + {S_{i - j + 3}*\Lambda_{j - 1}^{(i)}}},} & {1 \leq j \leq {vi}} \end{matrix} \right.$

As shown in Table 2, the error value polynomial Ω(x) is derived based on the error location polynomial Λ(x). In other words, Λ(x) is obtained first so as to obtain Ω(x). Moreover, as mentioned above, the parallel-to-serial interface has less regularity, so there still remains room for improvement.

SUMMARY OF THE INVENTION

Traditional parallel-to-serial interfaces are limited to the use of multiplexers. Therefore, an IBMA method and the related parallel-to-serial conversion method applied in the Reed Solomon decoder are disclosed in this invention, so as to increase throughput of the Reed Solomon decoder and decrease design and production costs.

A parallel-to-serial conversion method for IBMA in the Reed Solomon decoder is used for obtaining discrepancies in IBMA iterations, thereby acquiring an error location polynomial and an error value polynomial. Syndrome sequences for the calculation of discrepancies in IBMA iterations have fixed lengths, i.e., same lengths or the same number of syndromes. The number of syndromes is t+1, where t is the largest number of symbols that can be corrected of the error location polynomial. The feature that the syndrome sequences have the same lengths is based on the fact that the discrepancies are not affected if the coefficients of orders of the error location polynomial are zero.

The IBMA algorithm of the Reed Solomon decoder in accordance with the present invention is to derive discrepancies in IBMA iterations based on syndrome sequences, and the error location polynomial and error value polynomial are simultaneously obtained based on the discrepancies.

The Reed Solomon decoder of the present invention comprises a parallel-to-serial interface and an IBMA apparatus. The IBMA apparatus is coupled to an output end of the parallel-to-serial interface and comprises an error location polynomial solver configured to calculate an error location polynomial and an error value polynomial solver connected to an output end of discrepancies of the error location polynomial solver, so as to obtain an error value polynomial based on the discrepancies. The error location polynomial and the error value polynomial are obtained simultaneously.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 illustrates a known Reed Solomon decoder;

FIG. 2 illustrates a known parallel-to-serial interface corresponding to the IBMA architecture of Reed Solomon decoder;

FIG. 3 illustrates a known IBMA architecture of the Reed Solomon decoder;

FIG. 4 illustrates architecture for the calculation of the key equation based on architecture of FIG. 3;

FIG. 5 illustrates an operation block diagram of the Reed Solomon decoder of the present invention;

FIG. 6 illustrates a block diagram of the Reed Solomon decoder of the present invention;

FIG. 7 illustrates a parallel-to-serial interface of the Reed Solomon decoder using IBMA architecture in accordance with the present invention;

FIG. 8 illustrates a schematic diagram of IBMA architecture of the Reed Solomon decoder in accordance with the present invention; and

FIG. 9 is an IBMA algorithm flow chart of the Reed Solomon decoder in accordance with the present invention.

DETAILED DESCRIPTION OF THE INVENTION

The present invention will be explained with the appended drawings to clearly disclose the technical characteristics of the present invention.

FIG. 5 is a function block diagram of a Reed Solomon decoder in accordance with the present invention, including syndrome computation 51, IBMA algorithm 52, Chien search 53 and Forney algorithm 54. Syndrome computation 51 finds syndromes including information of error location and error value for separation of error location information and error value information in the IBMA algorithm 52. The separated data are resolved through the Chien search 53 and the Forney algorithm 54 for correction of a message r(x) stored in a delay RAM 55. r(x) is the received message, e(x) is channel noise, and c(x) is the transmission message.

FIG. 6 illustrates a Reed Solomon decoder in accordance with the present invention, which is modified in response to problems of prior art, so as to obtain error location polynomial and error value polynomial simultaneously, and provides a parallel-to-serial interface with high regularity for better performance. A Reed Solomon decoder 60 includes a syndrome calculator 61, a parallel-to-serial (PS) interface 62, an IBMA apparatus 63, a serial-to-parallel (SP) interface 64, a Chien search device (error location) 65, a Chien search device (error value) 66, a first-in-first-out (FIFO) circuit 67 and a Forney algorithm device 68.

In comparison with the traditional Reed Solomon decoder 10 of FIG. 1, the Reed Solomon decoder 60 only needs an IBMA apparatus 63 to simultaneously acquire the error location polynomial and the error value polynomial. Moreover, the calculation of the parallel-to-serial interface 62 is also improved to decrease hardware complexity.

An embodiment of the parallel-to-serial interface 62 is shown in FIG. 7, which comprises 16 serially connected syndrome cells 621. Multiplexers are not needed in the parallel-to-serial interface 62. The syndrome sequences are listed in Table 3, in which if X order of the polynomial is equal to zero, the corresponding syndrome values are not changed during iteration. Accordingly, the syndrome sequences are set to be of fixed length so as to acquire a parallel-to-serial interface with high regularity.

TABLE 3 Δ^((i)) Syndrome Sequences i = 0 S₁, S₁₆, S₁₅, S₁₄, S₁₃, S₁₂, S₁₁, S₁₀, S₉ i = 1 S₂, S₁, S₁₆, S₁₅, S₁₄, S₁₃, S₁₂, S₁₁, S₁₀ i = 2 S₃, S₂, S₁, S₁₆, S₁₅, S₁₄, S₁₃, S₁₂, S₁₁ i = 3 S₄, S₃, S₂, S₁, S₁₆, S₁₅, S₁₄, S₁₃, S₁₂ i = 4 S₅, S₄, S₃, S₂, S₁, S₁₆, S₁₅, S₁₄, S₁₃ i = 5 S₆, S₅, S₄, S₃, S₂, S₁, S₁₆, S₁₅, S₁₄ i = 6 S₇, S₆, S₅, S₄, S₃, S₂, S₁, S₁₆, S₁₅ i = 7 S₈, S₇, S₆, S₅, S₄, S₃, S₂, S₁, S₁₆ i = 8 S₉, S₈, S₇, S₆, S₅, S₄, S₃, S₂, S₁ i = 9 S₁₀, S₉, S₈, S₇, S₆, S₅, S₄, S₃, S₂ i = 10 S₁₁, S₁₀, S₉, S₈, S₇, S₆, S₅, S₄, S₃ i = 11 S₁₂, S₁₁, S₁₀, S₉, S₈, S₇, S₆, S₅, S₄ i = 12 S₁₃, S₁₂, S₁₁, S₁₀, S₉, S₈, S₇, S₆, S₅ i = 13 S₁₄, S₁₃, S₁₂, S₁₁, S₁₀, S₉, S₈, S₇, S₆ i = 14 S₁₅, S₁₄, S₁₃, S₁₂, S₁₁, S₁₀, S₉, S₈, S₇ i = 15 S₁₆, S₁₅, S₁₄, S₁₃, S₁₂, S₁₁, S₁₀, S₉, S₈

The syndrome sequence includes syndromes of orders of the polynomial not equal to zero and syndromes of orders of the polynomial equal to zero in reverse order. In each iteration, the syndromes in the previous iteration are shifted right, the rightmost syndrome is removed, and a syndrome next to the leftmost syndrome in the previous iteration is added to the left of the syndrome sequence. Syndrome sequences shown in Table 3 are selected from a sequence of S₁, S₁₆, S₁₅, S₁₄, S₁₃, S₁₂, S₁₁, S₁₀, S₉, S₈, S₇, S₆, S₅, S₄, S₃ and S₂. In each iteration, the rightmost syndrome of the sequence is moved to the far left side and the syndrome sequence includes the leftmost nine syndromes.

In response to the change of the parallel-to-serial interface 62, an IBMA algorithm is modified in accordance with the present invention. An IBMA algorithm is exemplified as follows.

Initial condition:

D⁽⁻¹⁾ = 0 δ= 1 β⁽⁻¹⁾(x) = x⁻¹ Λ⁽⁻¹⁾(x) = 1 T⁽⁻¹⁾(x) = 1 Ω⁽⁻¹⁾(x) = 0 Δ⁽⁰⁾ = S₁ For i=0 to 2t−1 { Δ^((i+1)) = S_(i+2) * Λ₀ ^((i)) + S_(i+1) *Λ₁ ^((i)) +...+S_(i−vi+2) *Λ_(vi) ^((i)) If Δ^((i)) =0 or 2D^((i−1)) ≧ i+1   D^((i)) = D^((i+1))   δ = δ   T^((i))(x) = x * T^((i−1))(x)   β^((i))(x) = x * β^((i−1))(x)   Λ^((i))(x) = Λ^((i−1))(x)   Ω^((i))(x) = Ω^((i−1))(x) Else   D^((i)) = i+1−D^((i−1))  δ = Δ^((i))   T^((i))(x) = Λ^((i−1))(x)   β^((i))(x) =Ω^((i−1))(x)   Λ^((i))(x) =δ * Λ^((i−1))(x) +Δ^((i))* x * T^((i−1))(x)   Ω^((i))(x) =δ * Ω^((i−1))(x) +Δ^((i))* x * β^((i−1))(x) }

where

-   -   Λ^((i))(x) is the error location polynomial at the ith iteration     -   Λ_(j) ^((i))(x) is coefficients of orders of Λ^((i))(x)     -   J is x order     -   Δ^((i)) is the discrepancy at ith iteration     -   δ is the discrepancy of T^((i))(x) with corrected iteration     -   T^((i))(x) is an auxiliary polynomial of Λ(x) at the ith         iteration.     -   D^((i)) is the highest order of the auxiliary polynomial     -   S(x) is a syndrome array S₁˜S_(2t)     -   Ω(x) is a key equation     -   β^((i))(x) is an auxiliary polynomial of Ω(x) at the ith         iteration

In order to have higher regularity and less complexity in hardware implementations, the serial input data sequence in the separated IBMA architecture is listed in Table 3, and the separated error location polynomial and key equation are shown in Table 4.

TABLE 4 Error location polynomial Key equation Λ^((i))(x) = Λ₀ ^((i)) + Λ₁ ^((i))x + . . . + Λ_(vi) ^((i))x^(vi) $\begin{matrix} {{\Omega (x)} = {{S(x)}{\Lambda (x)}\mspace{11mu} {mod}\mspace{11mu} x^{2t}}} \\ {\cong {\Omega^{(0)} + {\Omega^{(1)}x} + {\ldots \mspace{11mu} \Omega^{({v - 1})}x^{v - 1}}}} \end{matrix}$ $\Lambda_{j}^{(i)} = \left\{ \begin{matrix} {{\delta*\Lambda_{0}^{({i - 1})}},} & {j = 0} \\ {{{\delta*\Lambda_{j}^{({i - 1})}} + {\Delta^{(i)}T_{j - 1}^{({i - 1})}}},} & {1 \leq j \leq {vi}} \end{matrix} \right.$ $\Omega_{j}^{(i)} = \left\{ \begin{matrix} {\delta*\Omega_{0}^{({i - 1})}} & {{{for}\mspace{14mu} j} = 0} \\ {{\delta*\Omega_{j}^{({i - 1})}} + {\Delta^{(i)}\beta_{j - 1}^{({i - 1})}}} & {{{for}\mspace{14mu} 1} \leq j \leq {vi}} \end{matrix} \right.$ $\Delta^{({i + 1})} = {\sum\limits_{j = 0}^{vi}\; \Delta_{j}^{({i + 1})}}$ $\Delta_{j}^{({i + 1})} = \left\{ \begin{matrix} {0,} & {j = 0} \\ {{\Delta_{j - 1}^{({i + 1})} + {S_{i - j + 3}*\Lambda_{j - 1}^{(i)}}},} & {1 \leq j \leq {vi}} \end{matrix} \right.$

An IBMA apparatus 63 shown in FIG. 8 includes multipliers 81, 90, 91, 94 and 95, adders 83, 89 and 96, registers 84, 86, 88, 92 and 97, buffers 82, 97, 98 and 100, multiplexers (MUX) 85, 93 and 99. The upper devices 81-93 of the IBMA apparatus 63 constitute an error location polynomial solver 104, which is similar to a traditional IBMA architecture. Devices 94-100 constitute an error value polynomial solver 102. The discrepancy Δ^((i)) at the ith iteration is multiplied by the auxiliary polynomial β_(j-1) ^((i-1)) at (i−1)th iteration through the multiplexer 95, and discrepancy δ of T^((i))(x) having iteration with correction is multiplied by key equation Ω_(j) ^((i-1)), then the two results are added to be Ω_(j) ^((i)), so as to further acquire the key equation Ω(x). Accordingly, error location polynomial and error value polynomial, i.e., key equation, Ω(x), are obtained simultaneously based on Δ^((i)) and δ.

The error location polynomial Λ(x) and discrepancy Δ are calculated according to the following equations (1) and (2), respectively. Superscript (i) indicates the ith iteration of IBMA computation, and the discrepancy Δ is a value to determine whether error location polynomial Λ(x) in the next iteration needs to be corrected. When i is equal to 2t, the polynomial of the Reed Solomon decoder is in response to largest error symbol. Superscript v is the number of error symbol of the decoding correction v≦t.

Λ^((i))(x)=Λ₀ ^((i))+Λ₁ ^((i)) x+ . . . +Λ _(vi) ^((i)) x ^(vi)  (1)

Λ^((i))=Λ₀ ^((i)) S _(i+1)+Λ₁ ^((i)) S _(i)+ . . . +Λ_(v) ^((i)) S _(i+1−v)  (2)

Table 3 shows syndromes in each iteration. For example, discrepancy Δ at the 0th iteration is equal to Λ₀ ⁽⁰⁾S₀₊₁+Λ₁ ⁽⁰⁾S₀+ . . . +Λ_(v) ⁽⁰⁾S_(0+1−v). Initial Λ⁽⁰⁾(x)=1, therefore only the coefficient at zero order is not equal to zero, i.e., only S₁ is a meaningful syndrome. Because the coefficients of other orders are zero, the multiplication of zero and an arbitrary number are zero. Therefore, the calculation of Δ⁽⁰⁾ is not affected even if other syndromes are arbitrary numbers. Moreover, only a coefficient of an order of Λ(x) is increased in each iteration, and the largest order is less than one. Therefore, the problem of coefficients of orders of polynomials having no corresponding syndrome values will not occur in the computation of discrepancy Δ.

Consequently, based on the feature that no influence on computation of discrepancy Δ occurs when the coefficients of the orders of Λ(x) are equal to zero, the lengths of syndrome sequences for calculating Δ are fixed to be t+1 including pseudo codes not affecting discrepancy Δ, as shown in Table 3.

An IBMA computation is exemplified as follows.

i Λ^((i))(x) Δ^((i)) Ω^((i))(x) ν −1 1 1 X⁻¹ −1 0 1 S₁ 0 −1

Initial parameters are listed in the above table for the IBMA computations, and all elements of GF(8) are listed as follows

-   -   GF(8) constructed by p(x)=x³+x+1         -   0             (0, 0, 0)         -   α             (0, 1, 0)         -   α²             (0, 0, 1)         -   α³=α+1             (1, 1, 0)         -   α⁴=α²+α             (0, 1, 1)         -   α⁵=α²+α+1             (1, 1, 1)         -   α⁶=α²+1             (1, 0, 1)         -   α⁷=1             (1, 0, 0)

In the first iteration, Δ⁽⁰⁾ is not equal to zero; therefore Λ⁽¹⁾(X) and Ω⁽¹⁾(X) are corrected.

For the Δ⁽⁰⁾ calculation, it is equal to the multiplication of S₁ and Λ⁽⁰⁾(X). In this example, the number of corrections is two, so that the highest orders of the error location polynomial and error value polynomial are X². Therefore, the syndrome array can be of fixed lengths to match the highest order of the polynomial. Three syndromes are operated with X⁰, X¹, X², i.e., Δ⁽⁰⁾=[S₁ S₄ S₃]*Λ⁽⁰⁾(X)=[S₁ S₄ S₃]*[1 0 0]=S₁*1+S₄*0+S₃*0=α⁶.

v=−1 & i=0

Δ⁽⁰⁾=S₁=α⁶≠0

Λ⁽¹⁾(X)=Δ⁽⁻¹⁾*Λ⁽⁰⁾(X)+Δ⁽⁰⁾ *X ⁽⁰⁻⁽⁻¹⁾⁾*Λ⁽⁻¹⁾(X)

Λ⁽¹⁾(X)=1*1+S ₁ X ⁽¹⁾*1=1+S ₁ X=1+α⁶ X

Ω⁽¹⁾(X)=Δ⁽⁻¹⁾*Ω⁽⁰⁾(X)+Δ⁽⁰⁾ *X ⁽⁰⁻⁽⁻¹⁾⁾*Ω⁽⁻¹⁾(X)

Ω⁽¹⁾(X)=1*0+S ₁ X ⁽¹⁾ *X ⁻¹ =S ₁=α⁶

In the second iteration, Δ⁽¹⁾ is not equal to zero, therefore Λ⁽²⁾(X) and Ω⁽²⁾(X) are corrected.

For the Δ⁽¹⁾ calculation, it is equal to the multiplication of S₁, S₂ and Λ⁽¹⁾(X). In this example, the number of corrections is two, so that the highest orders of the error location polynomial and error value polynomial are X². Therefore, the syndrome array can be of fixed lengths to match the highest order of the polynomial. Three syndromes are operated with X⁰, X¹, X², i.e., Δ⁽¹⁾=[S₂ S₁ S₄]*Λ⁽¹⁾(X)=[S₂ S₁ S₄]*[1 α⁶ 0]=S₂*1+S₁*α⁶+S₄*0=α².

v=0 & i=1

Δ⁽¹⁾=Λ₀ ⁽¹⁾ S ₂+Λ₁ ⁽¹⁾ S ₁=α³+α⁵=α²≠0

Λ⁽²⁾(X)=Δ⁽⁰⁾*Λ⁽¹⁾(X)+Δ⁽¹⁾ *X ⁽¹⁻⁰⁾*Λ⁽⁰⁾(X)

Λ⁽²⁾(X)=α⁶(1+α⁶ X)+α² *X ⁽¹⁾*1

Λ⁽²⁾(X)=α⁶+α¹² X+α ² X=α ⁶+α³ X

Ω⁽²⁾(X)=Δ⁽⁰⁾*Ω⁽¹⁾(X)+Δ⁽¹⁾ *X ⁽¹⁻⁰⁾*Ω⁽⁰⁾(X)

Ω⁽²⁾(X)=α⁶α⁶+α² *X ⁽¹⁾*0=α⁵

In the third iteration, Δ⁽²⁾ is not equal to zero; therefore Λ⁽³⁾ (X) and Ω⁽³⁾(X) are corrected.

For the Δ⁽²⁾ calculation, it is equal to the multiplication of S₂, S₃ and Λ⁽²⁾(X). In this example, the number of corrections is two, so that the highest orders of the error location polynomial and error value polynomial are X². Therefore, the syndrome array can be of fixed lengths to match the highest order of the polynomial. Three syndromes are operated with X⁰, X¹, X², i.e., Δ⁽²⁾=[S₃ S₂ S₁]*Λ⁽²⁾(X)=[S₃ S₂ S₁]*[α⁶ α³ 0]=S₃α⁶+S₂*α³+S₁*0=α⁴.

v=1 & i=2

Δ⁽²⁾=Λ₀ ⁽²⁾ S ₃+Λ₁ ⁽²⁾ S ₂=α⁶*α⁴+α³*α³

Δ⁽²⁾=α³+α⁶=α⁴≠0

Λ⁽³⁾(X)=Δ⁽¹⁾*Λ⁽²⁾(X)+Δ⁽²⁾ *X ⁽²⁻¹⁾*Λ⁽¹⁾(X)

Λ⁽³⁾(X)=α²(α⁶+α³ X)+α⁴ *X ⁽¹⁾*(1+α⁶ X)

Λ⁽³⁾(X)=α+α⁵ X+α ⁴ X+α ³ X ² =α+X+α ³ X ²

Ω⁽³⁾(X)=Δ⁽¹⁾*Ω⁽²⁾(X)+Δ⁽²⁾ *X ⁽²⁻¹⁾*Ω⁽¹⁾(X)

Ω⁽³⁾(X)=α²*α⁵+α⁴ *X ⁽¹⁾*α⁶=α⁷+α³ X

In the fourth iteration, Δ⁽³⁾ is not equal to zero; therefore Λ⁽⁴⁾ (X) and Ω⁽⁴⁾(X) are corrected.

For the Δ⁽³⁾ calculation, it is equal to the multiplication of S₂, S₃, S₄ and Λ⁽³⁾(X). In this example, the number of corrections is two, so that the highest orders of the error location polynomial and error value polynomial are X². Therefore, the syndrome array can be of fixed lengths to match the highest order of the polynomial. Three syndromes are operated with X⁰, X¹, X² i.e., Δ⁽³⁾=[S₄ S₃ S₂]*Λ⁽³⁾(X)=[S₄ S₃ S₂]*[α 1 α³]=S₄*α+S₃*1+S₂*α³=α⁶.

v=2 & i=3

Δ⁽³⁾=Λ₀ ⁽³⁾ S ₄+Λ₁ ⁽³⁾ S ₃+Λ₂ ⁽³⁾ S ₂

Δ⁽³⁾=α*α³+1*α⁴+α³*α³

Δ⁽³⁾=α⁴+α⁴+α⁶=α⁶≠0

Λ⁽⁴⁾(X)=Δ⁽²⁾*Λ⁽³⁾(X)+Δ⁽³⁾ *X ⁽³⁻²⁾*Λ⁽²⁾(X)

Λ⁽⁴⁾(X)=α⁴(α+X+α ³ X ²)+α⁶ *X*(α⁶+α³ X)

Λ⁽⁴⁾(X)=α⁵+α⁴ X+X ²+α⁵ X+α ² X ²

Λ⁽⁴⁾(X)=α⁵ +X+α ⁶ X ²

Ω⁽⁴⁾(X)=Δ⁽²⁾*Ω⁽³⁾(X)+Δ⁽³⁾ *X ⁽³⁻²⁾*Ω⁽²⁾(X)

Ω⁽⁴⁾(X)=α⁴*(α⁷+α³ X)+α⁶ *X*α ⁵=α⁴+α⁵ X

Λ⁽⁴⁾(X) and Ω⁽⁴⁾(X) are the error location polynomial and error value polynomial, respectively, in this example.

FIG. 9 illustrates a flow chart for the IBMA algorithm. First, initial conditions are determined, and Δ^((i)) is calculated based on the initial conditions. If Δ^((i))≠0 or i−v≧2, the error location polynomial and the error value polynomial need to be corrected. The process is repeated by iterating i=i+1 if i<2t.

The above-described embodiments of the present invention are intended to be illustrative only. Numerous alternative embodiments may be devised by those skilled in the art without departing from the scope of the following claims. 

1. A parallel-to-serial conversion method of Inversionless Berlekamp-Massey Algorithm (IBMA) of a Reed Solomon decoder for obtaining discrepancies of IBMA iterations to derive an error location polynomial and an error value polynomial, comprising: setting syndrome sequences to be of same lengths when calculating the discrepancy in each IBMA iteration, wherein the number of syndromes of the syndrome sequences is t+1, and t is the largest number of symbols that can be corrected of the error location polynomial.
 2. The parallel-to-serial conversion method in accordance with claim 1, wherein the syndrome sequences set to be of same lengths are based on the feature that the discrepancies are not affected if coefficients of orders of the error location polynomial are zero.
 3. The parallel-to-serial conversion method in accordance with claim 1, wherein the syndrome sequence comprises syndromes of the orders of the error location polynomial not equal to zero and syndromes of orders of the error location polynomial equal to zero in reverse order.
 4. The parallel-to-serial conversion method in accordance with claim 1, wherein in each iteration the syndromes of the syndrome sequence in a previous iteration are shifted right, the rightmost syndrome is removed, and a syndrome next to the leftmost syndrome in the previous iteration is added to the left of the syndrome sequence.
 5. The parallel-to-serial conversion method in accordance with claim 1, wherein the syndrome sequence is selected from a sequence including syndromes, in each iteration the rightmost syndrome is moved to the far left side and the syndrome sequence includes the leftmost t+1 syndromes.
 6. An IBMA method of Reed Solomon decoder, comprising: obtaining discrepancies of IBMA iterations based on syndrome sequences; and simultaneously obtaining an error location polynomial and an error value polynomial based on the discrepancies.
 7. The IBMA method of Reed Solomon decoder in accordance with claim 6, wherein the syndrome sequence comprises syndromes of orders of the error location polynomial not equal to zero and syndromes of orders of the error location polynomial equal to zero in reverse order.
 8. The IBMA method of Reed Solomon decoder in accordance with claim 6, wherein in each iteration the syndromes of the syndrome sequence in a previous iteration are shifted right, the rightmost syndrome is removed, and a syndrome next to the leftmost syndrome in the previous iteration is added to the left of the syndrome sequence.
 9. The IBMA method of Reed Solomon decoder in accordance with claim 6, wherein the error value polynomial is obtained by using initial conditions and discrepancies in obtaining the error location polynomial to separate different information for the error location polynomial and the error value polynomial, thereby the error location polynomial and the error value polynomial are calculated in parallel.
 10. The IBMA method of Reed Solomon decoder in accordance with claim 6, wherein the syndrome sequences are of same lengths.
 11. A Reed Solomon decoder, comprising: a parallel-to-serial interface; and an IBMA apparatus connected to an output end of the parallel-to-serial interface and comprising: an error location polynomial solver configured to calculate an error location polynomial based on discrepancies of IBMA iterations; and an error value polynomial solver connected to an output end of the discrepancies of the error location polynomial solver and configured to calculate an error value polynomial based on the discrepancies; wherein the error location polynomial and the error value polynomial are obtained simultaneously.
 12. The Reed Solomon decoder in accordance with claim 11, wherein the error value polynomial solver comprises: a first multiplier by which the discrepancy is multiplied by an auxiliary polynomial of the error value polynomial; a second multiplier by which the discrepancy with corrected iteration is multiplied by a coefficient of the error value polynomial; and an adder by which multiplications obtained from the first and second multipliers are added to be a coefficient of next order of the error value polynomial.
 13. The Reed Solomon decoder in accordance with claim 11, wherein syndrome sequences of the parallel-to-serial interface are set to be of same lengths when calculating the discrepancy in each IBMA iteration, and the number of syndromes of the syndrome sequences is t+1, and t is the largest number of symbols that can be corrected of the error location polynomial.
 14. The Reed Solomon decoder in accordance with claim 13, wherein the syndrome sequence comprises syndromes of orders of the error location polynomial not equal to zero and syndromes of orders of the error location polynomial equal to zero in reverse order.
 15. The Reed Solomon decoder in accordance with claim 13, wherein in each iteration syndromes of the syndrome sequence in a previous iteration are shifted right, the rightmost syndrome is removed, and a syndrome next to the leftmost syndrome in the previous iteration is added to the left of the syndrome sequence.
 16. The Reed Solomon decoder in accordance with claim 11, further comprising a syndrome calculator configured to provide syndromes to the parallel-to-serial interface.
 17. The Reed Solomon decoder in accordance with claim 11, further comprising a Chien search device configured to solve an error location based on the error location polynomial and the error value polynomial. 